//存在一个按升序排列的链表，给你这个链表的头节点 head ，请你删除链表中所有存在数字重复情况的节点，只保留原始链表中 没有重复出现 的数字。 
//
// 返回同样按升序排列的结果链表。 
//
// 
//
// 示例 1： 
//
// 
//输入：head = [1,2,3,3,4,4,5]
//输出：[1,2,5]
// 
//
// 示例 2： 
//
// 
//输入：head = [1,1,1,2,3]
//输出：[2,3]
// 
//
// 
//
// 提示： 
//
// 
// 链表中节点数目在范围 [0, 300] 内 
// -100 <= Node.val <= 100 
// 题目数据保证链表已经按升序排列 
// 
// Related Topics 链表 双指针 
// 👍 643 👎 0

/**
 * @author DaHuangXiao
 */
package leetcode.editor.cn;
public class RemoveDuplicatesFromSortedListIi {
    public static void main(String[] args) {
        Solution solution = new RemoveDuplicatesFromSortedListIi().new Solution();
    }
    //leetcode submit region begin(Prohibit modification and deletion)
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode deleteDuplicates(ListNode head) {
        ListNode hair = new ListNode(-1);
        // tail有效链表尾部
        ListNode tail = hair;

        while (head!=null) {
            // 已经到头，或者head下一个不重复时，可以更新tail
            if (head.next==null || head.next.val!=head.val){
                tail.next = head;
                tail = tail.next;
                head = head.next;
            }else {
                // 如果head与下一个重复，则跳过重复值
                while (head.next != null && head.next.val == head.val) {
                    head = head.next;
                }
                // 跳过重复的
                head = head.next;
            }
        }
        // 尾部置空
        tail.next = null;
        return hair.next;
    }
}
//leetcode submit region end(Prohibit modification and deletion)

}